草庐IT

C++ iostream 输入输出流

全部标签

ruby-on-rails - 重定向 Rails 3 中特定 Controller 的记录器输出

我们想要一个Controller集合,我们将所有操作和下游方法的记录器输出路由到一个单独的日志文件。这是一个Rails3项目。在Rails2中,我们通过重新定义“logger”方法来做到这一点,但在Rails3中,记录的方式是使用“Rails.logger”。我试着把Rails::logger=Logger.new(File.join(Rails.root,'log',"reports_controller.log"),10,1000000)在Controller的顶部,但只有在操作中专门使用Rails.logger的特定情况才会发送到指定的日志文件,Controller的所有默认日志

ruby - 使用 Octokit.rb 输出 repos URL

我正在尝试使用Octokit.rb列出Github帐户存储库的详细信息,但似乎无法找到关联的URL。首先,我需要做的就是使用OAuth通过GithubAPI进行身份验证,并将详细信息输出到控制台。到目前为止,这是一个基本示例:client=Octokit::Client.new:access_token=>'my_token'client.repos.eachdo|repo|putsrepo.nameputsrepo.description#html_url&clone_urlgohere.end我确定我忽略了一些明显的东西,但是您需要做什么才能找到html_url、clone_url

ruby - 如何在 ruby​​ 中使用反引号开始子进程的连续输出

我有一个ruby​​应用程序,它使用反引号将ant作为子进程执行。这没有任何问题。当我执行putant时,ruby等待子进程ant完全完成,然后将输出打印到标准输出。如何让ruby​​连续打印子进程的输出? 最佳答案 你可以使用IO.popen。IO.popen("ant")do|output|whileline=output.getsdo#...maybeputsline?somethingmoreinteresting?endend 关于ruby-如何在ruby​​中使用反引号开始子

ruby - 如何循环请求用户输入,直到用户输入正确的信息?

我是一名正在尝试学习Ruby的初学者。到目前为止,我已经学到了一些比较简单的东西,但我似乎一直在尝试将我学到的一些东西结合起来。我想做的是问用户一个问题并告诉他们输入1或2。一个简单的if语句可以让我在他们输入1时用一个选项响应,在他们输入2时用另一个选项响应。但是,如果他们输入完全不同的内容,例如不同的数字、字符串等,我该如何提示他们重试并让它循环回到原始问题?到目前为止,我所拥有的看起来像这样。prompt=">"puts"Questionaskingfor1or2."printpromptuser_input=gets.chomp.to_iifuser_input==1puts"

ruby - 如何使用 Rake 为 Rspec 运行 JunitFormatter 输出?

我可以使用以下方式运行rspec文件:rspec-fJUnitFormatter-ojunit.xmlspec_test.rb但是每次我尝试rake执行spec文件时,我都会收到以下错误/formatters/junit_formatter.rb:28:in`require':nosuchfiletoload--rspec/core/formatters/base_formatter(LoadError)from./formatters/junit_formatter.rb:28from/usr/lib/ruby/1.8/spec/runner/option_parser.rb:151

ruby - 为什么在重定向时,Ruby 的 STDERR 输出先于 STDOUT 输出?

在bash中,这给出了预期顺序的输出:ruby-e"puts'one';raise'two'"one-e:1:in`':two(RuntimeError)但是如果我将STDERR重定向到STDOUT,我会在输出之前收到错误,这是我不想要的:ruby-e"puts'one';raise'two'"2>&1|cat-e:1:in`':two(RuntimeError)one我想将输出重定向到一个文本文件(它的行为方式与上面的cat相同)并获得输出和异常,但顺序与查看我的输出时的顺序相同终端。这能实现吗? 最佳答案 发生这种情况是因为行缓

ruby - 为什么 Logger 输出到 STDOUT 不会重定向到文件?

这个脚本被命名为o.rb:@logger=Logger.new(STDOUT)@logger.info"start_time:#{start_time}"当我使用./o.rb运行它时,控制台上的输出是正确的。但是,当我尝试./o.rb>log.txt2>&1时,日志文件是空的!为什么会这样?我在使用简单的puts函数时遇到了同样的问题。更新这将重现此问题:require'logger'logger=Logger.new(STDOUT)loopdologger.info"Thisisatesthaha"sleep(1)end当我使用./foo.rb运行它时,它会正确写入控制台输出。当我运

ruby-on-rails - 更改模型的输入名称

使用ActiveAttr:classFilterincludeActiveAttr::Modelattributeterm#Overridingto_key,to_param,model_name,param_keyetcdoesn'thelp:(endclassSpecialFilter我如何覆盖ActiveModel以生成(相同的)所有子类的预定义输入名称?=form_forSpecialFilter.new,url:'xx'do|f|=f.text_field:term所以不是我需要得到注意:这个场景要复杂得多(有simple_form和radios/checkboxes/dro

ruby - Capistrano 3.x 逐行捕获输出

在Capistrano2.x中,您可以使用以下命令逐行捕获输出run"ls-la"do|channel,stream,data|putsdataend这在Capistrano3.x中不起作用,capture和execute命令似乎不提供相同的功能。有没有办法在3.x中复制2.x的行为? 最佳答案 output=capture('cat~/file.cnf')output.each_linedo|line|putslineend这就是我使用捕获读取行的方式。如果您想捕获一行中的特定内容,您可以使用ifline.include?'use

ruby-on-rails - 将 TrueClass/FalseClass 的值输出为整数或字符串/

我想弄清楚是否有一种简单的方法来执行以下操作,而不是将to_i方法添加到TrueClass/FalseClass。这是一个难题:我的Rails应用程序中有一个bool字段-显然在mysql中存储为Tinyint。但是-我需要根据mysql中的数据生成xml并将其发送给客户-那里的SOAP服务要求相关字段具有0或1作为该字段的值。因此,在生成xml时,我需要将False转换为0,将True转换为1(这就是它们在数据库中的存储方式)。由于True&False缺少to_i方法,我可以编写一些if语句,根据真/假状态生成1或0。然而,我有大约10个这样的指标,并且为每个指标创建和if/else